草庐IT

SQL 和转义的 XML 数据

全部标签

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby-on-rails - ActiveRecord 与两个数据库对话?

我们最近改进了一个项目,希望将我们所有的旧数据带入新系统。问题在于架构略有不同,因此无法直接导入SQL。由于一些非规范化和数据库更改,我们需要在数据准备好导入之前对数据进行一些处理。我希望是这样的:OldUser.all.eachdo|ou|NewUser.create({:first_name=>ou.first_name:last_name=>ou.last_name:login=>ou.login:company_name=>ou.company.name})end在上面的示例中,OldUser正在从旧数据库读取数据,而NewUser正在处理新数据库。我需要两组模型(新的和旧的)

ruby-on-rails - Heroku 上的数据库连接

哇,我已经被困在这个问题上好几天了。我无法连接到Heroku上的database.yml。我在使用Cedar和ruby​​1.9.2。我的开发和测试数据库是sqlite3,生产数据库是postgreSQL以应对Cedar规则。这是我的ruby​​脚本中的代码:Rails.env.production??(env="production"):(env="development")dbconfig=YAML::load(File.open('config/database.yml'))[env]ActiveRecord::Base.establish_connection(dbconfig

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby - 使用 VCR 过滤敏感数据

我正在使用VCRgem来记录http交互并在将来重播它们。我想在uri请求中过滤掉我的实际密码值。以下是uri的示例:http://services.somesite.com/Services.asmx/CabinsUsername=long&Password=john&StartDate=03%2F22%2F2012&EndDate=03%2F29%2F2012虽然这里提供了解释,但我自己尝试了几次后仍然不确定如何去做:https://www.relishapp.com/myronmarston/vcr/v/2-0-0/docs/configuration/filter-sensit

Ruby CSV 解析带有转义引号的字符串

我的CSV文件中有一行包含一些转义引号:173,"Yukihiro\"TheRubyGuy\"Matsumoto","Japan"当我尝试使用RubyCSV解析器解析它时:require'csv'CSV.foreach('my.csv',headers:true,header_converters::symbol)do|row|putsrowend我收到这个错误:.../1.9.3-p327/lib/ruby/1.9.1/csv.rb:1914:in`block(2levels)inshift':Missingorstrayquoteinline122(CSV::MalformedCS

ruby - 在 Ruby/Rails 中,如何对 URL 中的特殊字符进行编码/转义?

在使用OpenURIopen(url)之前如何对URL进行编码或“转义”?我们正在使用OpenURI打开远程url并返回xml:getresult=open(url).read问题是URL包含一些包含空格和其他字符的用户输入文本,可能包括“+”、“&”、“?”等,因此我们需要安全地对URL进行转义。我在使用Net::HTTP时看到了很多示例,但没有找到任何用于OpenURI的示例。我们还需要能够对在session变量中收到的类似字符串进行反转义,因此我们需要倒数函数。 最佳答案 不要使用URI.escape,因为它已在1.9中弃用。

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p

ruby-on-rails - Rails 5 SQL 注入(inject)

我已经在各种SO线程、指南等上阅读了一段时间...但所有答案都是相互矛盾和矛盾的。好像有很多类似的方法,而且很多答案都说使用不同的方法。清理sanitize_conditionssanitize_sqlsanitize_sql_arraysanitize_sql_for_assignmentsanitize_sql_for_conditionssanitize_sql_hashsanitize_sql_hash_for_assignmentsanitize_sql_hash_for_conditionssanitize_sql_like我正在尝试编写一个“原始查询”适配器,让我可以运行

__END__ 之后的 Ruby 数据范围

我将这个Ruby技巧与__END__和DATA结合使用,将一些数据放入我的程序文件中:classFoodefinitialize()putsDATA.read.inspectendendputsDATA.read.inspectFoo.new__END__test这会生成以下输出:"test"""我曾假设DATA在全局范围内是相同的,但在类内部它没有任何内容。我将如何在类内访问__END__之后的数据(除了使用全局变量的明显且丑陋的解决方案之外)?ADDED:我看到读取DATA两次如何让我第二次没有任何反应。我可以使用rewind回到开头,但是read会给我程序的全部源代码。在DATA